<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>淘宝购物车</title>
</head>
<body>
    <table border="1" align="center" cellpadding="10">
        <thead>
            <tr>
                <th>
                    <input type="checkbox" id="selectAll" onclick="selectAll()"> 全选
                </th>
                <th>
                    商品名称
                </th>
                <th>商品单价</th>
                <th>数量</th>
                <th>小计</th>
                <th>操作</th>
            </tr>
        </thead>
        <tbody id="tb">
            <tr id="row_1">
                <td><input type="checkbox" class="checkbox"></td>
                <td>滑板鞋</td>
                <td>138</td>
                <td>
                    <input type="button" value="-" onclick="changeNum('row1','-')">
                    <input type="text" value="1" readonly id="row1" />
                    <input type="button" value="+" onclick="changeNum('row1','+')">
                </td>
                <td></td>
                <td>
                    <input type="button" value="删除" onclick="delRow('row_1')">
                </td>
            </tr>
            <tr id="row_2">
                <td><input type="checkbox" class="checkbox"></td>
                <td>高跟鞋</td>
                <td>239</td>
                <td>
                    <input type="button" value="-" onclick="changeNum('row2','-')">
                    <input type="text" value="1" readonly id="row2" />
                    <input type="button" value="+" onclick="changeNum('row2','+')">
                </td>
                <td></td>
                <td>
                    <input type="button" value="删除" onclick="delRow('row_2')">
                </td>
            </tr>
            <tr id="row_3">
                <td><input type="checkbox" class="checkbox"></td>
                <td>短袖衬衫</td>
                <td>108</td>
                <td>
                    <input type="button" value="-" onclick="changeNum('row3','-')">
                    <input type="text" value="1" readonly id="row3" />
                    <input type="button" value="+" onclick="changeNum('row3','+')">
                </td>
                <td></td>
                <td>
                    <input type="button" value="删除" onclick="delRow('row_3')">
                </td>
            </tr>
            <tr id="row_4">
                <td><input type="checkbox" class="checkbox"></td>
                <td>运动短裤</td>
                <td>57</td>
                <td>
                    <input type="button" value="-" onclick="changeNum('row4','-')">
                    <input type="text" value="2" readonly id="row4" />
                    <input type="button" value="+" onclick="changeNum('row4','+')">
                </td>
                <td></td>
                <td>
                    <input type="button" value="删除" onclick="delRow('row_4')">
                </td>
            </tr>
        </tbody>
    </table>
    <div>
        <input type="button" value="删除所选" onclick="delSelected()">
        总价：<span id="total"></span>
    </div>  
</body>
   <script>
    productCount();   //productCount:总计。
    function $(ele){
       return document.querySelector(ele); //返回获取文档中 id="ele"的元素
   }
   
   //计算价格部分。
    function productCount(){
    //总价格
    let total=0;    //total:总计
    //单价 
    let price=0;
    //数量 
    let num=0;
    //小计
    let subtotal=0;

    // 获取tbody中的行数
    let trs=$('#tb').getElementsByTagName('tr');
    // 获取每一行中的td
    for( let i=0;i<trs.length;i++ ){
            price = trs[i].getElementsByTagName('td')[2].innerText;
            num = trs[i].getElementsByTagName('td')[3].getElementsByTagName('input')[1].value
            subtotal = price*num;
            subtotal = trs[i].getElementsByTagName('td')[4].innerText;
            total += subtotal;
        }
        $('#total').innerText = total;  
        
    }
     
    // 改变数量
     function changeNum(numId,ope){ //数量的ID。
        if(ope == '+'){
            $(`#${numId}`).value = +$(`#${numId}`).value+1;
        }else{
            if( $(`#${numId}`).value<=1 ){
                alert('商品数量不能少于1');
                return;
            }
            $(`#${numId}`).value = +$(`#${numId}`).value-1;
        }
        productCount();
    }
    
    // 删除单行
    function delRow(rowId){ // 行的id
        // let trs = $('#tb').getElementsByTagName();
        $('#tb').removeChild( $(`#${rowId}`) ); //removeChild:从列表中删除一个项目。
        productCount();
    }
     
    // 全选、全不选
     function selectAll(){
        //返回id为checkbox的dom。
        let checkboxes = document.querySelectorAll('.checkbox');
        
        for( let i=0;i<checkboxes.length;i++ ){
            checkboxes[i].checked = $('#selectAll').checked
        }
    }
    
    function delSelected(){ //selected:删除当前选项。
        let checkboxes = document.querySelectorAll('.checkbox');
        let trs = $('#tb').getElementsByTagName('tr');
        
        for( let i=checkboxes.length-1;i>=0;i-- ){
            if(checkboxes[i].checked == true){
                $('#tb').removeChild(trs[i]);
            }
        }
        productCount();
    }
</script>
</html>